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(57) Abstract: This invention relates to methods of 
searching for a final number of resull strings (30-33) 
having a partial or an exact match with a query string 
(34) in a database (80) comprised of many long 
strings or a long string, said method includes the steps 
of partitioning the query string in a first number of 
input query strings (35, 36, 37); determining a second 
number of neighboring strings (38-41, 42-45, 44-49, 
respectively) for each string in said first number of 
input query strings, wherein each string in said second 
number of neighboring strings has a predetermined 
first number of errors; searching the database for a 
third number of exact matches (50-61, 70-74) for each 
string in said second number of neighboring strings 
based on a search method; concatenating said searched 
exact matched strings from the database into a fourth 
number of intermediate strings (29, 30, 32, 33, 34) 
wherein said searched exact matched strings (50-61, 
70-74) comprised in each of said intermediate strings 
are in succession to one another in said database; and 
determining the final number of result strings (30-33) 
based in said fourth number of intermediate suings, 
wherein each string in the final number of result strings 
has a maximum of predetermined second number of 
errors compared to said query string (34). This enables 
for a perfect match or a partial match containing only 
minor errors with respect to said quciy string, and for 
a fast search in larger databases with a relative low use 
of processing powa:. 
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Method and arrangement for searching for strings 



This invention relates to a method of searching for a final number of result 
strings having a partial or an exact mach with a query strmg in a database comprised of many 
long strings or of a long string. 

The present invention also relates to a search engine. 
5 The present invention also relates to a tool 

The present invention also relates to a computer system for perfonning the 

method. 

Hie present invention furflier relates to a computer program product for 
performing the method. 
10 Additionally, the present invention further relates to an arrangement. 

US 5,963,957 discloses an information processing system having a music 
database. Said music database stores homophonic reference sequences of music notes. The 
reference sequences are all normalized to the same scale degree in order to be stored 
iexicogr^hically. A so called N-aiy is applied to find a match between a string of input 
15 music notes and a particular reference sequence. Hereby said information processing system 
provides bibliographic information associated with the matching reference sequence. 

In Du, D.W. and Chang, S.C. (1994), an approach to designing very fast 
approximate string matching algorithms, IEEE Transactions on Knowledge and Data 
Engineering, 6, 4, 620-633, another kind of string matching is further disclosed. 
20 In the art, retrieval methods use algorithms for exact matching. However the 

known retrieval methods typically attempt an exact match, i.e. the search or the match is 
performed in order to find a perfect match. 

However, it is a problem in many practical applications that only a perfect 
match is searched for. As a result, it is an additional problem that no matchmg result(s) is/are 
25 provided even though this/these may be useful even if it/they only contained minor errors. 

It is a further problem that search of large database takes a long time and 
correspondingly requires intensive usage of processing power. 

In many practical applications it is su£5cient to obtain a partial match (instead 
of the perfect match). This is the case since either a query string - as an input to the search 
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attempt - or the result matching string, both may have less important errors but still it is 
better to obtain the partial match result than no result at all. Said errors, typically, are caused 
by improper data comprised either in the query string or in the database searched in. 

The above and other problems are solved by said method, when the method 
5 comprises the steps of: 

partitioning the query string m a first number of input query strings; 

In other words, in this step, the query string is cut into said first number of 
small pieces of substrings, i.e. into said input query strings. 

determining a second number of neighboring strings for each string in said 
10 first number of input query strings, wherem each string in said second number of nei^boring 
strings has a predetermined first number of errors; 

In otlier words, in this step, the second number of neighboring strings depends 
of the length of the query string, the size of different discrete symbols in the string alphabet 
applied and the numbers of errors allowed in tlie neighboring strings. 
15 In general, for each string in said first number of input query strings said 

second number of neighboring strings are determined. Each of these, individually has a 
predetermined first number of errors, which is greater than or equal to zero. 

searching the database for a third number of exact matches for each string in 
said second number of neighbormg strings based on a search method; 
20 Hereby, is the database searched for a number (third) of exact matches for 

each string in said second number of neighboring strings based on a given search method, the 
search method can be a q-gram index method, a suffix tree method or a hash method. 

concatenating said searched exact matched strings from the database into a 
fourth number of intennediate strings wherein said searched exact matched strings comprised 
23 in each of said intennediate strings are in succession to one another in said database; and 

determining the final number of result strings based on said fourth number of 
intermediate strings, wherein each string in the final number of result strings has a maximum 
of a predetermined second number of errors compared to said query string. 

For &e last two steps, these are explained in figure 5, i.e. step 400 and SOO, 
30 As a result of the method, said final number of result strings, each is an exact 

or a partial match to said query string (mentioned m the opening paragraph). 

It is hereby achieved to obtain a perfect match or a partial match containing 
only minor errors. 
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Further, the method can search large databases (for perfect or partial matches) 
fast with a relative low use of processmg power. 

Said arrangemeut, tool, search engine, computer system, respectively provides 
the same advantages and solves the same problem(s) for the same reasons as described 
5 previously in relation to the mefliod. 

The invention will be explained more fiiUy below in connection with preferred 
embodiments and with reference to the drawings, in which: 

Fig. 1 shows a general discussion of the art; 

Fig. 2 shows a way of partitioning the query string; 
10 Fig. 3 shows a practical detailed example way of partitioning the query strmg 

and a subsequent search; 

Fig. 4 shows a general example way of partitioning and searching the queiy 

string; 

Fig. 5 shows a method of searching for a final number of result strings, and 

15 Fig. 6 shows an arrangement for searching. 

Throughout the drawings, the same reference numerals indicate similar or 
corresponding features, functions, strings, etc. 

Figure 1 shows a general discussion of the art. The figure shows a query string 
'abacababc' searched for in a string database, reference numeral 80. The database positions 

20 of the four approximate matches of the query string allowing at most one error (k = 1) are 
indicated. The query string, reference numeral 34,'abacababc' which is composed from a 3- 
letter alphabet {*a','b','c'}. If only one error (k- 1) is allowed, an approximate match is 
found containing an added symbol (e.g., reference numeral 30: 'abacadabbc'), an 
approximate match containing a deleted symbol (e.g., reference numeral 31 : 'abcababc'), an 

25 approximate match containing a substituted symbol (e.g., reference numeral 32: 'abacadcbc') 
and an exact match (i.e., reference numeral 33: 'abacadabc'). It is generally acknowledged in 
the art to search for a string whereby the entire query string is searched for at once. 

Figure 2 shows a way of partitioning the query string. Efficient retrieval 
methods, known from tiie literature, capitalize on the use of fast algorithms for exact 

30 matching, that is, searching without allowing any error (or, k- 0). This would only return the 
position for (exact) match, i.e. reference numeral 33 from figure 1. Specialized index 
structures such as suffix trees or ^-grams need to be build off-line (as a pre-processor) from 
the string database, reference numeral 80 to enable the implementation of fast exact matching 
algorithms. Essentially, these structures keep hold of all positions of each small sub-string 
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that occur in the database. Effectively, this means that the retrieval process can immediately 
jump to fee relevant spots in fee database while discarding fee inelevant parts. The g-gram 
index mefeod is used, since it is more space-efficient (i.e., uses less memory) fean ofeer 
mefeods and can be easily adapted to our purpose. The ^-gram keeps all positions of all sub- 
5 strings of lengfe q>0 occurring in fee database. If, for instance, fee database consists of fee 

string *abababcabcabacab fee q-gram wife g = 4 collects fee starting positions of all 

sub-strings of length 4 such as 'abab', *baba', 'abab% 'babe' and *abca'. These sub-strings are 
indexed by using a function, listed and sorted in an easily accessible data structure. Sunilar 
sub-strmgs, such as 'abab' in fee example, end up at fee same index (called a bucket). A 

10 gram allows us to obtain fee database positions of all exact matches of a query of lengfe 
m<q by computing fee index function and retrieve fee members of a bucket. Queries that 
are longer than q need an additional check because only fee prefixes of lengfe q of fee query 
can be m a bucket The standard way to work wife ^-grams is described by Myers, 1994. 

As alternatives to said q-gram mefeod, a sufibc tree method or a hash method 

IS may be applied. 

If exact matching mefeods are used m approximate matching, a workaround 
has to be found for fee errors allowed. For instance, according to fee invention a set of strings 
can be generated feat differ on a limited number of locations in fee original query (string). 
These strings are called neighbors of fee query. Neighbors feus represent fee errors in a 

20 query. Formally, a ^^-neighborhood of a string S is defined as fee set of strings wife at most k 
errors wife respect to S. For instance, if fee query 'abba' is constructed from fee two-letter 
alphabet {*a','b'}, fee complete set of neighbors wife at most one error (i.e., error level 
/c < 1) consists of fee original 'abba', all strings wife a deletion 'abb', 'aba' and 'bba', all 
strings with a addition 'aabba', 'babba', 'abbba', 'ababa', 'abbaa' and 'abbab' and all strings 

25 wife a substitution 'bbba', 'aaba', 'abaa' and 'abbb'. 

Neighbors of a given string can be efficiently generated (Myers, 1994). If fee 
neighbors are located in fee database using the ^-gram mefeod, feese exact matches 
correspond to approximate matches of fee original query. 

However, fee number of neighbors to be investigated is exponential when 

30 longer queries are investigated, a larger alphabet and a higher error level. To resolve feis 

issue and gain retrieval speed, fee query is first partitioned in smaller sub-strings and for each 
sub-string its set of neighbors is generated. Then all these neighbors are searched exactly 
using ^-grams or fee other search methods mentioned. Their exact matches in fee database 
correspond now to partial approximate matches of fee original query. 
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Let the queiy be 'abacababc* composed from the three-letter alphabet 
{'a','b','c'} and allow an error level of 3 (A = 3). Note that errors in the query can occur at 
any place. For instance, the errors can be 

all at the start (e.g., 'ccccababc' can then be the string you are actually looking 

5 for), 

all m the middle (e.g. 'ababbcabc'), 

all at the end (e.g., 'abacabbca') 

or unifonnly distributed m the query (e.g., 'abccacabb'). 

If the query is partitioned into three parts (p = 3, which results in the 
10 substrings 'aba', *cab' and 'abc' for our example query 'abacababc'), a set of neighbors is 
generated for each part and each neighbor is searched individually in the database, context is 
lost about how the original query looks like. To understand this, note that the neighbors can 
occur anywhere in the database. Neighbors do not necessarily appear close together or in a 
sequence, which is required to form an approximate match of the original query. In other 
15 words, when an exact match is found for a neighbor for our example query 'abacababc', it 
cannot be known whether it reflect the first, second or third part of the query and what kind 
of neighbors are found for the other parts. Necessary measures have to be taken to reveal this 
information. Former methods described in literature stop right here, that is, they consider 
each exact match of a neighbor as a useful candidate for resolving the queiy. In contrast, the 
20 invention of cross-cutting does an additional filter step by re-establishing the (error) context 
while searching the neighbors. The neighbors that can be discarded are 

those that do not appear in sl sequence with other neighbors in the database, 

and 

those that form a sequence with other neighbors in the database that cannot be 
25 an approximate match of the original query. 

These observations are condensed in a central 'cross-cutting| lemma for the 
current invention that provides a guarantee about the successful retrieval of relevant parts if 
we partition a query string in p parts and search for the parts separately each with at most 
kf en'ors. 

30 Cross-cutting lemma: Let A and B be two strings such that the number of 

errors between them is smaller than or equal to ^ in edit-distance sense, or formally 
d(A,B)<k .Let ^4 = ^41^42 •••^4^ be the partitioning Amp parts, for strings and for any 

p > 1 . Let ii: = (/:i , ^2 ) • • • > ) be any sequence of nonnegative numbers such that 
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C = X^^j ki+p-k>l. Then there exists a partitioning -5 = 53^2 - •• -5^ and a subset of the 

parts indexed by J ^U\J2.'">Ji) suchthat 

Proof: It is evident that B can be partitioned in p parts such that 

Xz^l ^^^i > ) = 3(^5 ■ '00^ *® errors are located at corresponding parts and do 

5 not introduce additional errors. We choose such a partitioning of B and all parts / in the 
subset J for which A,- + 1 ^ 9(^1, ) .Now we can derive the following which proves our 
case: 

/=i /=i ^=1 

The lemma is used as a filtration condition ui the invention with A beuig the 
10 queiy string and B the database string. The lemma says that the number of errors that a 
sequence of neighbors in the database represents, has to fulfil a particular criterion. For that 
criterion, is applied as the pre-defined number of errors tiiat are allowed in each sub-string 

p 

i of the query. Then, the error summation ^ (^/ + 1) - e should be at least a constant 

/=1 

P 

C -^k^ ■\' p-k\oht still part of an approximate match of the query. In these formulae, p is 

r=l 

15 the number of sub-strings in which the query string is partitioned, ki is the number of errors 

allowed in each sub-string and k is the maximum total number of errors (enor level). 

p 

Calculating the error summation X(*i + 1) - e and comparing it to C is the 

/=1 

foundation of the cross-cuttmg algorithm. Shortly, each time a new match of a neighbor has 
been found at a particular position in tiie database, it is checked whether or not tliere are 

20 matches of other neighbors preceding that database position. Specialized data structure keeps 
track of all the positions of the neighbors in the database in an efficient way. Then, it is 
verified whether or not the concatenation of these consecutive matches (as they appear m the 
database) can eventually result in an ^proxhnate match of fte complete query. If the error 
summation is equal or larger than the threshold C, tiian these neighbors are still relevant 

25 candidates for being part of an approximate match of the query. If the error summation is 
lower than this threshold C, all involved neighbors can be discarded. 
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P 

= 1 and C = ^^|+/?-A = 3. For each sub-string, a set of neighbors i.e. reference 



As shown in figure 2, Ae query 'abacababc', reference numeral 34, is 
partitioned in three sub-strings (jp = 3). Recall that only 3 errors are allowed {k = 3). Define 

k_ 
P\ 

numeral 38-41, 42-45 and 46-49, respectively is generated which are sought exactly in the 
5 database. In the process of neighbor search, the positions of all neighbors found so far are 
kept and it is decided whether or not the concatenation of consecutive neighbors can be part 
of an approximate match of the query. The two matches for the neighbors 'aba' and 'cab' 
(see reference numeral 30 in figure 2) represent an error-fiw match of the first two sub- 

2 

strmgs of the query string (i.e., g = 0 and ^(A:,- +1) - e = 4 > C = 3). Already it is known that 

/=! 

10 a valid approximate match of the query have been found; in the worst case a neighbor 

representing 3 errors can succeed tliese two matches for which om filtration condition still 
holds. The two matches for the neighbors 'abc' and 'caa' (see 31 in figure 2) represent 2 
2 

errors (i.e,, e = 2 and ^ (/k,- + 1) - e = 2 ). This sequence can only be succeeded by a neighbor 

representmg at most 1 error to be still a valid approximate match of the query. The matches 
15 for the neighbors 'acb' and 'cbc' (see reference numeral 32 in figure 2) represent already 4 

2 

errors (i.e., e = 4 and) ^(^j- +1) - e = 0 . It is already known that this sequence cannot be 

i=\ 

part of an approximate match of the query. Even if it is succeeded by an error-fi-ee neighbor, 
the filtration condition does not hold. 

For a more detailed and general discussion of said Q-grams and said 
20 Neighboring generation, respectively; the followings sections should enable the person 
skilled in the art to implement the invention: 

Q-grams or the q-gram index method: 

With q-grams it is possible to find all occurrences of a string not bigger than q 
IS very fast Those q-grams are constructed in the following way. 

Consider a bijection ^ of the symbols in £ to the integers 0 to <j - 1 . 
Function^ is naturally extended to strings with tlie recursive definition 
^{Pa) = (J^{P) + ^(a) where P is a string over 2 and c is a symbol in 2 . For 
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6e[0,C7^-l],let ^Mcfer(Z>)=: {f :^(a/a,+i = That is, Bucket{b) gives the 

indices of the leftmost character of each occurrence in j4 of the unique ^-symbol string whose 
^ -code is b. 

The index is produced in the following way. First = ^(^ZfOf+i is 
5 computed for every index /. This is done m an.0^n^ sweep of A using the observation that 
= aiCr"^"^ + /<T J. With an 0(n /og(nJ»>quick-sort the list can now be produced 
Indices = (z'l j /2 ) such that 0^-^. < 0/^.^^ . Finally, the array 

Header[b] = mm\j : ^i„dices[j] = is produced in an 0(n) sweep of Indices, The arrays 

Indices and Header provide a realization of the Bucket sets. Namely, 
10 Bucket[b] = {lndices[j] : j € [Header[blHeader[b + 1] -1]}. 

If a query P is of lengfli m<q then all indices of the occurrences of P are 

exactly flie contentof Bucket(b)for 6e [0(i')o-^-''',(0(P)+l)a-^"''" -1]. 

If a query P is larger than q it is knovm that the occurrences of P must be a 
subset of those in Bucket((l>{Pg)) where Pg denotes the string consisting of the first q symbols 

15 ofP. 

Neighbor generation: 

A (complete) Ar-neighborhood of a string P is defined as the set of all strings 
with a (edit-)distance less than or equal to k from P, i.e. (P)='\Q' 9(i2> P)^k:}, 

20 A condensed /c-neighborhood of a string P is defined as the set of all strings in 

the complete ^-neighborhood of P that do not have a prefix in that neighborhood, i.e., 
Cjt (jP) = fe : g 6 A^^ (P) and no prefix of Q is in Nf, (P)}. 

Myers' algorithm computes a condensed k-neighborhood of a string efficiently 
by generating words from an alphabet and computing the corresponding rows of the dynamic 

25 programming matrix of the currently generated word and P. If a word whose last entry of the 
current row equals k, then a word in the condensed k-neighborhood has been reached. If all 
entries are larger than k, the algorithm can backtrack. Tlie use of failure links prevents the 
algorithm from missing words that are in the k-neighborhood but are not in the condensed 
one. 

30 As the present invention needs the complete k-neighborhood of a string to find 

all exact matches of the partitions in the database, Myers's algorithm has been adapted. 
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Figure 3 shows a practical detailed example way of partitioning the query 
string and a subsequent search. 

The queiy string, reference numeral 34, again is searched for in the database, 
reference numeral 80. According to the invention, said query string is partitioned into a 
5 number of input query strings, the number three is here chosen for conciseness, it may be any 
other number greater than one. In the example, said input query strings are represented by 
reference numeral 35, 36 and 37, respectively for the beginning part, liie middle part and the 
"end part" - part. 

By means of said number of input query strings, a number of neighboring 
1 0 strings - here four - is defined for each input query string. I.e. for the input query string of 
reference numeral 35, corresponding four neighboring strings, reference numeral 38, 39, 40 
and 41 are determined 

Correspondingly, for the "mid part" input query string of reference numeral 

36, corresponduig four neigjibormg strings, reference numeral 42, 43, 44 and 45 are 
15 determined. 

Correspondingly, for the "end part" input query string of reference numeral 

37, corresponding four neighboring strings, reference numeral 46, 47, 48 and 49 are 
determined. 

To the right of the dotted line, reference numeral 80, it is implied that in this 
20 section of the figure, the database - previously also indicated by the same reference nimieral - 
is searched into, i.e. said neighboring strings, reference numeral 38 - 49, each is searched for 
in order to find exact (sub string) match(es). 

These are indicated by following the arrows further to the right; as an 
example, reference numeral 38, a first part neighboring string gives the exact match of 
25 reference numeral 50; as another example, reference numeral 47, an end part neighboring 
string gives the match of reference numerals 58 and 61, and reference numeral 45, a mid part 
neighboring string gives tlie "none- useful" result of reference numeral 72. 

And in order to achieve final search result(s), more or less matching the query 
string, reference numeral 34; the arrows can be followed further to the right, i.e. reference 
30 numeral 30-33, respectively indicate each of the four final search results. As can be seen, 
each of said final search results is always comprised of one of the searched beginning 
substrings, reference numemi 50-53, one of the mid searched substrmgs, reference numeral 
54-57 and one of the "end part" searched substrings, reference numeral 58-61. How these are 
put in succession and by which criterions will be explained by means of figure 5. 
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Figure 4 shows a general example way of partitioning and searching the query 
string. Figure 4 corresponds to figure 3, however, generally the 's indicate that any string 
of any reference numeral may comprise fewer or more letters, i.e. the invention can be 
applied for veiy short strings and for very long sequence of letters as well. 
5 The letters of the western alphabet - as shown - may alternatively be a 

sequence of elements in a pitch alphabet, a sequence of elements in a musical pitch interval 
alphabet, a sequence of elements in a musical time interval alphabet, a sequence of binary 
digits, words or bytes, a sequence of amino acids or a sequence of DNA/RNA. 
Correspondingly, the same applies for the database searched in, since it may also be 

10 understood as one long string or of many long strings. 

Said sequence of elements in a musical pitch interval alphabet and sequence of 
elements m a musical time interval alphabet represents the essence of a musical score. In 
general for all strings (the query string, strings in the database, etc) this means that these can 
be made out of any alphabet of discrete symbols. 

15 Figure 5 shows a method of searching for a final number of result strings. The 

method searches for a final number of result strmgs as indicated by means of reference 
numerals 30 through 33 (in the foregoing figures). I.e. each of said fmal number of result 
strings will have a partial or an exact mach with the query string, reference numeral 34 in the 
database, if possible. The database, reference numeral 80, is comprised of a long string. Said 

20 method comprises the following steps: 

In step 100, the query string is partitioned in a fu-st number of input queiy 
strings. As indicated in the forgoing figures, said query string is partitioned in three iuput 
query strings, reference numerals 35, 36 and 37, i.e. the first number is here three. Said first 
number may be any number greater than or equal to one. The first number equaling exact 

25 three is only shown for illustrative purposes, i.e. any higher or lower number may be chosen 
as well. 

In other words, in this step, the query string is cut into (said first number) 
small pieces of substrings, i.e. into said input query strings. 

In the example, the query string, reference numeral 34, "aba cab., abc" is cut 
30 into said set of first number of input query strings, in the example there are three m the set, 
i.e. input query string 1, reference numeral 35 = "aba..", input query string 2, reference 
numeral 36 = "cab.." and input query string 3, reference numeral 37 = "abc". 

In step 200, a second number of neighboring strings are determined. As also 
indicated in Ihe forgoing figures, said second number of neighboring strings is four, i.e. 
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reference numerals 38-41 for the first input query string reference numeral 35, reference 
numerals 42-45 for the second or mid input query string, reference numeral 36 and reference 
numerals 44-49 for the third or last mput query string, reference numeral 37. 

The second number equaling exact four is only shown for illustrative 
5 purposes, i.e. any higher or lower number than four may be chosen as well. In particular, the 
number of neighboring strings depends of the length of the query string, the size of different 
discrete symbols in tiie string alphabet applied and the numbers of errors allowed in the 
neighboring strings. 

This gives, as the example a total of twelve neighboring strings, i.e. it equals 
10 said first number times said second number, i.e. 3x4=12, i.e. four for each (three) input 
query strings; or in general: for each string in said first number of input query strings said 
second number of neighboring strings are determined. As indicated in the forgoing figures, 
these are the reference numerals 38 through 49. Each of these, individually has a 
predetermined fu-st number of errors, which is greater than or equal to zero. 
1 5 Note that If the (first) number of errors exceeds the neighboring string length 

(i.e, all content of the string is then determined to be in error), consequently a subsequent 
search in the next step would be absolutely meaning less; therefore said first number of errors 
cannot exceed the string length. 

As the example given, on basis of the input query string "aba..", i.e. reference 
20 numeral 35, four neighboring strings are determmed, i.e.: 

reference numeral 38 "aba.." equalmg itseli^ .i.e. of course no errors. 

reference numeral 39 "abc." with one error, 

reference numeral 40 "abb.." with another error, and 

reference numeral 41 "acb.." with two errors. 
25 In the example given, the predetermined first number of errors (which is 

greater than or equal to zero) is here 0, 1 or 2. 

The first number of predetermined of errors, m the example equaling zero, one 
or two, is only shown for illustrative purposes, i.e. any higher number may be chosen as well. 

In step 300, the database is searched for a thh-d number of exact matches for 
30 each string in said second number of neighboring strings. Said search is based on a given 
search method. 

Said third number of exact matches is illustrated by means of reference 
numerals 50-61 and 70-74. It is important to note that there may be one or more matches, 



* 
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firstly, reference numeral 38 "aba.." - as an example of a neighboring string - 
leads to the exact match of reference numeral 50 and 52, i.e. "aba.."; 

secondtyj reference numeral 39 "abc." - as another example of a neighboring 
string - leads also to its exact match of reference numeral 51 "abc", 
5 - tiiirdly, reference numeral 40 "abb" leads also to no match, i.e. reference 

numeral 70 "abd.." and 

finally, reference numeral 41 "acb" also leads to no match, i.e. reference 
numeral 71 "abc". 

The latter two is then unusable since only exact matches are considered. 
10 Correspondingly, reference numerals 53-61 and 72-74 are search results from 

the neighboring strings indicated by means of reference numerals 42 - 49. 

In all cases, the search results, reference numerals 50-61 and 70-74, with 
corresponding string content and corresponding positions in the database are kept for later 
use in tiie subsequent step. 
15 Also, in all cases, the given search method may be the q-gram index method or 

any other appropriate method known to be useful in the art, e.g. a suffix tree method or a 
hash method. 

In step 400, said searched exact matched strings from the database are 
concatenated into a fourth number of intermediate strings. Said searched exact matched 
20 strings (when comprised in each of said intermediate strings) are in succession to one another 
in said database. 

Said fourth number of intermediate strings is indicated by means of reference 
numerals 29 - 33, the fourth number in the example given is five. Further, said searched exact 
matched strings - indicated by means of reference numerals 50-61 and 70-74 - comprised in 
25 each of said intermediate strings are determined to be in succession to one another in said 
database: this will be explamed in the following: 

As can be seen from the examples - during concatenation - search result from 
tiie first input query string (bemg the beginning of Hie query string), reference numeral 35 = 
"aba.." having corresponding beginning neighboring strings, reference numeral 38 - 41 lead 
30 to corresponding beginning substrings, reference numeral 50-53. 

Correspondingly, - during concatenation - search result from the second input 
query string (being the middle of the query string), reference numeral 36 = "cab.." having 
correspondmg "middle" neighboring strings, reference numeral 42-45 lead to corresponding 
mid substrings, reference numeral 54-57. 
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Correspondingly, - during concatenation - search result from the third input 
query string (being the end part of the query strmg), reference numeral 37 = "abc." having 
corresponding "end part" neighbormg strings, reference numeral 46 - 49 lead to 
corresponding "end part" substrings, reference numeral 58-61. 
5 In other words, the exact matched strmgs, reference numerals 50-61 and 70-74 

as corresponding part of each of said intermediate strings are in &ct ui succession to one 
aiiother m the database, i.e. one of the beginning substrings, reference numeral 50-53, one of 
the mid substrings, reference numeral 54-57 and one of the end part substrmgs, reference 
numeral 58-61 are concatenated into one of said fourth number of intermediate strings, i.e. 

1 0 one of reference numerals 29-33 . 

In step 500, the final number of result strings is determined. The determination 
is based on said fourth number of intermediate strings from the foregoing step, and here - in 
this step - each string in the fmal number of result strings is determmed to have a maxhnum 
of a predetermined second number of errors compared to said query string of reference 

15 numeral 34. 

In tiie examples given, the final number of result strings, reference numerals 
30-33, is four, whereas said fourth number of intermediate strings was five. Le. in the 
example, one, reference numeral 29 is discarded or left out since this in particular does not 
satisfy the criterion of having error(s) less than or equal to said second number of errors. This 

20 is seen when compared to said query string, of reference numeral 34. 

In other words, reference numeral 29 is discarded for havmg too many errors 
(compared the initial query string of reference numeral 34), whereas reference numerals 30 
through 33, individually had less errors and thus satisfied the criterion. That is, in the 
example reference numerals 30 through 33 comprise the final number of result strings. 

25 As a result of the method, said final number of result strings, reference 

numerals 30 - 33, each is an exact or a partial match to said query string, reference numeral 
34. 

In the example given, four matches (exact or partial) was then the result when 
said query string was searched for. 
30 This step - in coimection with the foregoing step - is also called "Cross- 

cutting", i.e. the idea of considering only those exact matches of neighbors (when searched 
for) that, when concatenated, can contam an approximate match with the original query string 
of reference numeral 34. 
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In the spirit of the invention, any of said "first number", "second number of 
neighboring strings", "third number" *f ourth number of intermediate strings" and ^'first and 
second number of errors, may be fine tuned individually or in relation to one another or in 
relation to the content of the query string and / or the database. Hereby either speed of search 
S may be decreased and / or another matching (fewer/less) errors may be obtained. 

Correspondingly, the given examples are iUustmtive and may also be 
expanded vdth another string length for the query string, neighbormg strings, intermediate 
strings, another sequential content (of discrete symbols) of the strings, etc. 

Figure 6 shows an arrangement for searching. Reference numeral 660 

10 indicates said arrangement The arrangement processes - according to the invention - the 
query string, reference numeral 34 as discussed in the foregoing figure. The arrangement 
processes said string as input and therefore comprises calculation means 661, e.g. a sufficient 
fast microprocessor. The microprocessor searches for matches in the database, reference 
numeral 80. As a result, if any, the final number of result strings, reference numeral 30, 3 1, 

15 32 and 33 is found. The calculation means for carrying out the steps of the matching method 
can also be e.g. a part of a dedicated ASIC. 

Reference numeral 662 denotes a computer program product. Said computer 
program product comprising program code means stored on a computer readable medium for 
performing said method when the computer program is run on a computer, 

20 Generally, the present invention may be applied in various fields, such as 

melody retrieval for music systems ('query by hununing'), finding keywords in a search 
engine or m a text file, finding DNA/RNA sequences in a molecular biology database, bits, 
bytes or word codes, error control, etc. For the melody retrieval application, it can be 
imagined that only a small fiagment of a melody is remembered without recaUing the 

25 complete melody or song. Once provided in the appropriate representation as a string of 
discrete symbols, this melody fi^gment can then be input to fte search method to reveal the 
identity of the song or melody using said database. The search method thereby allows for 
errors in the input. The arrangement may be e.g. a jukebox -implemented as a stand alone 
audio apparatus or on a PC. It may also be a portable audio apparatus, which contains an 

30 interfece enabling e.g. a jogger to quickly change his accompanymg music by whistling the 
begmning or refi-ain. The arrangement may e.g. also be a service on an internet server for 
quickly selecting a particular MPS fi-om the web, or the arrangement may be a portable phone 
running the method, for retrieving e.g. a ring tone. 
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Similarly, keywords as a query (similar to previously mentioned query string) 
for a search engine -e.g. for searching a particular product on Internet or a word in a software 
dictionary- or a software search tool can contain typos. The search or retrieval process can 
account for these errors in the keywords. In all applications, the number of errors one allows 
5 may be pre-defined and fixed. The database can be best seen as one very long string (e.g., a 
long text, all melodies in the world put into sequence, etc). Also, the strmgs may be 
constructed fi'om a finite collection (e.g. western or pitch alphabet, binary digits, bytes, 
words, amino acids, DNA/RNA, words, etc). For a text application, Ifae 26 letters fi'om Ihe 
Western alphabet may be used. Correspondingly, melodies can be constructed fi'om a 9- 
10 element pitch interval alphabet Molecular biology applications use the twenty amino acids or 
the four nucleotides as the alphabet. Coding applications use the binary symbols, word, bits 
or bytes. 

Under the essence of a musical score should be understood any information 
which is sufficient for retrieving a melody. E.g. tone intervals, or just time intervals in case a 

15 person is not very musical or wants to search a piece of music by e.g. tapping his foot, or 
both. These are converted into string characters by a predetermined mapping function. 

A computer readable medium may be magnetic tape, optical disc, digital 
versatile disk (DVD), compact disc (CD record-able or CD write-able), mini-disc, hard disk, 
floppy disk, smart card, PCMCIA card, etc. 

20 In the claims, any reference signs placed between parentheses shall not be constructed as 

hmiting the claim. The word "comprising" does not exclude the presence of elements or steps 
other than those listed in a claim. The word "a" or "an" preceding an element does not 
exclude the presence of a plurality of such elements. 

The invention can be implemented by means of hardware comprising several 

25 distinct elements, and by means of a suitably programmed computer. In the device claim 
enumerating several means, several of these means can be embodied by one and tiie same 
item of hardware. Ibe mere fact that certain measures are recited in mutually different 
dependent claims does not indicate that a combination of these measures cannot be used to 
advantage. 
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CLAIMS: 



1. A method of searching for a final number of result strings (30-33), having a 
partial or an exact match with a query string (34), in a database (80) comprised of many long 
strings or a long string, said method comprising the steps of: 

partitioning (100) the query string in a first number of input query strings (35, 

5 36,37); 

determining (200) a second number of neighboring strings (38-41, 42-45, 44- 
49, respectively) for each string in said first number of input query strings, wherein each 
string in said second number of neighboring strings has a predetermined first nimiber of 
errors; 

10 - searching (300) the database for a third number of exact matches (50-61, 70- 

74) for each string in said second number of neighboring strings based on a search method; 

concatenating (400) said searched exact matched strings fi-om the database 
into a fourth number of intermediate strings (29, 30, 32, 33, 34) wherein said searched exact 
matched strings (50-61, 70-74) comprised in each of said intermediate strings are in 

1 5 succession to one another in said database; and 

determining (500) flie final number of result strings (30-33) based on said 
fourth number of mtermediate strings, wherein each string in the final number of result 
strings has a maximum of a predetermined second number of errors compared to said query 
string (34). 

20 

2. A method according to claim 1 characterized in that said search method is a q- 
gram index method. 

3. A method according to claim 1 characterized in that said search method is a 
25 suffix tree method. 



4. A method according to claim 1 characterized in that said search metliod is a 

hash method. 



I 



wo 2004/079631 



18 



PCT/IB2004/050148 



5. A method according to any one of claims 1 to 4 characterized in tiiat said 
strings and said database each comprises a sequence of letters of the western alphabet 

6. A method according to any one of claims 1 to 4 characterized in that said 
5 strings and said database each represents the essence of a musical score. 

7. A method according to any one of claims 1 to 4 characterized in that said 
strings and said database each comprises a sequence of binary digits. 

10 8. A method according to any one of claims 1 to 4 chai*acterized in that said 

strings and said database each comprises a sequence of amino acids or a sequence of 
DNA/RNA bases. 



9. A method according to any one of claims 1 to 4 characterized in that said 

15 strings and said database each comprises a sequence of bits, bytes or words. 

1 0- A search engine comprising calculation means (661) for carrying out the steps 

of the methods according to clams 1 to 9. 

20 11. A tool comprising means for carrying out the steps of the methods according 

to claims 1 to 9. 



12. An arrangement (660) comprising: 

calculation means for (661) partitioning the query string in a first number of 
25 input query strings (35, 36, 37); 

calculation means for (661) determining a second number of neighboring 

strmgs (38-41, 42-45, 44-49, respectively) for each string in said first number of input query 

strmgs, wherem each string in said second number of neighboring strings has a 

predetermined furst number of errors; 
30 - calculation means for (661) searching the database for a thurd number of exact 

matches (50-61, 70-74) for each string in said second number of neighbormg strings based on 

a search method; 

calculation means for (661) concatenatmg.said searched exact matched strmgs 
from the database into a fourfli number of intermediate strings (29, 30, 32, 33, 34) wherein 
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said searched exact matched strings (50-61, 70-74) comprised in each of said intermediate 
strings are in succession to one another in said database; and 

calculation means for (66 1 ) determining the final number of result strmgs (3 0- 
33) based on said fourth number of intermediate strings, wherein each string in the final 
5 number of result strings has a maximum of a predetermined second number of errors 
compared to said query string (34). 

13. A computer system for performing the method according to any one of claims 
1 through 9. 

10 

14. A computer program product (662) comprising program code means stored on 
a computer readable medium for performing the method of any one of claims 1 through 9 
when the computer program is run on a computer. 
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